其他
Facebook 开源 Go 实体框架 Ent 支持 TiDB
原文作者:Amit Shani,Ent Engineer
对于后端开发者来说,一款好用的框架能够大大提升应用的开发效率。为了降低开发者使用 TiDB 的门槛,方便开发者快速连接到 TiDB,我们也在和合作伙伴一起,逐步完善面向主流开发语言和框架的连接支持。
近日,Facebook 开源的 Golang 实体框架 Ent 完成了对 TiDB 数据库的支持。
Ent 是一款易于构建和维护应用程序与大数据模型的框架。具有以下特点:· Schema 即代码:能将任何数据库表建模为 Go 对象;· 轻松地遍历任何图形 :可以轻松地运行查询、聚合和遍历任何图形结构;· 静态类型和显式 API:使用代码生成静态类型和显式 API,查询数据更加便捷;· 多存储驱动程序:支持 MySQL、PostgreSQL、SQLite、Gremlin,现在也已经支持了 TiDB;· 可扩展:易于扩展和使用 Go 模板自定义。
Hello World 应用示例
2. 在本地拷贝 hello world 的示例 repo
在这个示例 repo 中我们定义了一个简单的 User schema
func (User) Fields() []ent.Field {
return []ent.Field{
field.Time("created_at").
Default(time.Now),
field.String("name"),
field.Int("age"),
}
}
然后,连接 Ent 和 TiDB:
client, err := ent.Open("mysql", "root@tcp(localhost:4000)/test?parseTime=true")
if err != nil {
log.Fatalf("failed opening connection to TiDB: %v", err)
}
defer client.Close()
// Run the auto migration tool, with Atlas.
if err := client.Schema.Create(context.Background(), schema.WithAtlas(true)); err != nil {
log.Fatalf("failed printing schema changes: %v", err)
}
可以看到,在第一行我们通过一个 MySQL 语句去连接 TiDB Server,因为 TiDB 是兼容 MySQL 的,所以不需要其他特殊的 driver。话虽如此,TiDB 和 MySQL 还是有很多不同,尤其是与 Schema 迁移相关的操作,比如 SQL 诊断和迁移规划。所以,Atlas 可以自动监测出是连接到 TiDB,做相应的迁移处理。此外,第七行我们使用 schema.WithAtlas(true),表示 Ent 是使用“Atlas”作为迁移引擎。Atlas 是 Ent 刚刚发布的迁移引擎,得益于 Atlas 的最新设计,对新数据库的支持也变得前所未有的简单。
最后,我们新建一条 user 数据,并保存到 TiDB 中,以用于后需的数据读取和输出。
client.User.Create().
SetAge(30).
SetName("hedwigz").
SaveX(context.Background())
user := client.User.Query().FirstX(context.Background())
fmt.Printf("the user: %s is %d years old\n", user.Name, user.Age)
3. 运行这个示例程序:
the user: hedwigz is 30 years old
在这次快速演练中,我们成功实现了:· 启动一个本地的 TiDB 实例;· 连接 Ent 和 TiDB 数据库;· 使用 Atlas 迁移 Ent Schema;· 使用 Ent 从 TiDB 中插入和读取数据;
版本说明
原文:https://pingcap.com/zh/blog/facebook-ent-supports-tidb
往期推荐
我是 polarisxu,北大硕士毕业,曾在 360 等知名互联网公司工作,10多年技术研发与架构经验!2012 年接触 Go 语言并创建了 Go 语言中文网!著有《Go语言编程之旅》、开源图书《Go语言标准库》等。
坚持输出技术(包括 Go、Rust 等技术)、职场心得和创业感悟!欢迎关注「polarisxu」一起成长!也欢迎加我微信好友交流:gopherstudio